草庐IT

java - 从 TCP 流中读取多行

全部标签

java - 用于故障排除的指标模式分析

当我解决一些站点问题时,我需要检查许多指标,例如CPU、内存、应用程序指标等。通常,我想自动了解以下项目(无需人工一一检查所有指标):在此期间有多少指标出现峰值。如果指标X与指标Y具有相同的模式如果度量X具有一些周期性特征。对于第1项和第2项,我想我可以通过计算一些变化率来得到它。对于第3项,我目前还不知道。我的问题是:我们是否已经有一些可以在这里使用的库,语言(Go、Java、Python都可以)。您对需求3有什么建议吗?=====更多背景:我已经设置了Prometheus(监控系统),但我的问题是我想自动分析这些指标。例如:用户输入:这里有1000个时间序列数据,我在时间1到时间2

sockets - 如何发现客户端正在从 go 中的 tcp 缓冲区读取

我开始在一个项目中使用golang相当长的时间。在我的项目中,我必须实现一个响应tcp客户端的tcp服务器。服务器必须向客户端发送大量消息。问题是,当服务器向客户端连接写入消息时,它必须等到客户端从缓冲区读取该消息,然后再发送另一条消息(服务器必须等到客户端调用reader.ReadString('\n')方法)。在我的服务器代码中我写了:for{data:=但服务器将所有消息发送给客户端,而无需等待客户端中的ReadString。如何让服务器等到客户端读取一条消息,然后再发送另一条消息? 最佳答案 我认为要么赋值不明确,要么你误解

go - 从 yaml 文件中以自定义格式读取配置

我有一个YAML格式的配置文件。我正在尝试以某种自定义格式读取配置。我猜不出我可以使用的任何模式,比如树、json等。例如。应用程序.yamlorganization:products:product1:manager:"Rob"engineer:"John"product2:manager:"Henry"lead:"patrick"配置文件可能包含大量信息,并且因文件而异。我想按以下格式构造数据,organization/products/product1/manager=Roborganization/products/product1/engineer=Johnorganizat

sockets - 如何处理 go 中的粘性 tcp 数据包?

我有一个tcp服务器和一个客户端,服务器执行以下操作funcproviderCallback(connnet.Conn){reader:=bufio.NewReader(conn)varerrerrorfor{lenbyte,_:=reader.Peek(4)reader.Discard(4)slen:=int(binary.BigEndian.Uint32(lenbyte))data,err=reader.Peek(slen)process(data)reader.Discard(slen)}}客户端发送数据包的速度似乎快于进程可以处理的速度,因此我想在bufio中缓冲请求并稍后处理

go - 读取 http 响应时内存使用量增加

我正在开发一个工具,其中有300个从公共(public)云下载文件的例程。所有例程都并行地逐block下载文件(云支持api)。我最初创建了一个给定大小的文件和内存映射它。现在我正在使用io.ReadFullapi将响应主体直接读入内存映射byteslice。这样,内存最终会达到100%。 最佳答案 就我而言,复制移动就像您分配一个新数组并将元素复制到其中一样,内存将是初始数组的两倍大小。顺便说一句,从http响应体读取数据后,你应该关闭它,比如:deferresp.Body.Close()

java - 如何将等效的 GO 代码转换为 Java 代码?

我正在使用Java库进行RPC调用,我正在从需要转换为Java的GO代码中获取引用。我对go语法一无所知。任何人都可以帮我描述以下代码:Params:[]interface{}{from,//firstparameterisaddresstosendfrom(wheretheZECcomesfrom)[]interface{}{map[string]interface{}{"amount":msgval,"address":to,"memo":hex.EncodeToString([]byte(msg)),},},下面是如何,我正在尝试等效的Java代码:Mapparams=newHa

algorithm - 读取和写入同一 channel 的工作池去

我需要你的帮助。目前,我正在尝试创建一个工作池,该工作池从一个channel读取连续的作业,然后将结果生成到它正在读取的同一channel,然后进行工作并将结果生成到同一channel。你的想法有点像递归。有什么办法可以使这成为可能吗?我真的很感激您关于设计模式的建议,以使用go例程作为工作池和channel来实现此解决方案以读取作业,然后从同一工作池将该作业的结果写入同一channel以继续工作。谢谢你。 最佳答案 没有理由不能(从Go的角度)在读取后写回channel:funcFoo(cchanint){x:=虽然这很奇怪……老

mysql - 如何插入多行

我实际上是Go的新手,所以想知道像这样插入数据的最佳方式{"moduleId":"M101","topicId":["tt","ee"]}在MySQL数据库中使用GotypeTopicModulestruct{ModuleIdstring`json:"moduleId"bson:"moduleId"form:"moduleId"`TopicId[]string`json:"topicId"bson:"topicId"form:"topicId"`AddedBystring`json:"addedBy"bson:"addedBy"form:"addedBy"`}funcAddTopicM

Golang : Recursive function for reconnecting a TCP client. .. 坏主意?

我有这个有效的TCP客户端代码。当它在TCP连接上写入或读取失败时,它会使用递归函数tcpReconnect()创建一个新连接。这安全吗?它会填满RAM吗?它可能会在几天(周末或节假日)后尝试重新连接。此代码是监视工业机器状态的驱动程序的一部分。也许这个问题有更好的解决方案。我找不到。PS:我不喜欢投票packagemainimport("fmt""net""time")varpollTime=1000//msvarhost="127.0.0.1"varport="11000"funcmain(){finished:=make(chanbool)goDriver()

json - 读取 map[string]interface{} 中的数据

源服务器返回多个对象的Json格式的数据接口(interface),我们如何解析这些数据?我正在使用JSONmap[string]interface{}类型的变量来保存来自服务器的结果ThedatareturnfromServer."data":[{"group":"PAA_TEST","id":"2018-04-10T09:24:18.000000Z","name":"PAA_STATION","released":true,"version":33},{"group":"PAA_TEST","id":"2018-03-19T10:50:21.000000Z","name":"PAA